- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 633
fix(#2794): sshfs compatibility #2893
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great! Nice and simple.
Please also leave a comment about the use case that this test addresses and why.
        
          
                lua/nvim-tree/explorer/explore.lua
              
                Outdated
          
        
      | end | ||
|  | ||
| local abs = utils.path_join { cwd, name } | ||
| t = t or (vim.loop.fs_stat(abs) or {}).type | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is an extra (not expensive as usually short circuited) call to fs_stat.
Could we put this after line 44?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moved after line 44, please review.
Co-authored-by: Alexander Courtis <alex@courtis.org>
| This is working really nicely. The new files/directories are being picked up as soon as the OS sees them. 
       -- Type must come from fs_stat and not fs_scandir_next to maintain sshfs compatibility
      local type = stat and stat.type or nil
      log.line("dev", "populate_children %.06s\t%.06s\t%s", vim.inspect(t), vim.inspect(type), abs)Adding a directory does work, however you need to close/open the containing folder. | 
| We need to go further: there are other places that need this fix. Reload is the most obvious case which will resolve the add case above: remove-file looks to be a similar case. Please look for all cases of broken functionality or use of  | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I spoke too soon when claiming this was simple...
| Good catch on the create/delete/reload functionality. I did not think to test that. I added the same type checking for reloading and deletion and in my testing, remote folders seem to behave identical to local folders. Please confirm and let me know if any further changes are needed. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Works nicely, many thanks for your contribution.
As you're working with sshfs I'd be most grateful for future PRs if you discover similar issues in the future.
This reverts commit 2d6e64d.
Added type fallback to make nvim-tree work with sshfs.
fixes #2794